<?php
/**
 * @package		简易CMS
 * @subpackage	页面模块管理模块
 * @version		$Id: admincp_block.php 23 2012-06-11 18:04:03Z htmambo@gmail.com $
 * @author		Hoping
 * @copyright	Copyright (C) 2010 Hoping Software Studio.
 */


if(!defined('IN_JYCMS') || !defined('IN_ADMINCP')) {
	exit('Access Denied');
}

cpheader();
$operation = in_array($operation, array('jscall', 'list')) ? $operation : 'list';

shownav('portal', 'block');
loadcache('blockclass');

if(submitcheck('deletesubmit')) {
	if($_POST['ids']) {
		$_POST['ids'] = daddslashes($_POST['ids']);
		DB::query("DELETE FROM #__common_block_item WHERE bid IN (".dimplode($_POST['ids']).")");
		DB::query("DELETE FROM #__common_block WHERE bid IN (".dimplode($_POST['ids']).")");
		cpmsg('block_delete_succeed', 'action=block&operation=jscall', 'finished');
	} else {
		cpmsg('block_choose_at_least_one_block', 'action=block&operation=jscall', 'error');
	}
} elseif(submitcheck('clearsubmit')) {
	include_once libfile('function/block');
	block_clear();
	cpmsg('block_clear_unused_succeed', 'action=block', 'finished');
} else {
	loadcache(array('diytemplatename'));
	$searchctrl = '<span style="float: right; padding-right: 40px;">'
	.'<a href="javascript:;" onclick="$(\'#tb_search\').show();$(\'#a_search_show\').hide();$(\'#a_search_hide\').show();" id="a_search_show" style="display:none">'.cplang('show_search').'</a>'
	.'<a href="javascript:;" onclick="$(\'#tb_search\').hide();$(\'#a_search_show\').show();$(\'#a_search_hide\').hide();" id="a_search_hide">'.cplang('hide_search').'</a>'
	.'</span>';
	showsubmenu('block',  array(
	array('block_list', 'block', $operation=='list'),
	array('block_jscall', 'block&operation=jscall', $operation=='jscall')
	), $searchctrl);
	$mpurl = ADMINSCRIPT.'?action=block&operation='.$operation;
	$intkeys = array('bid');
	$strkeys = array('blockclass');
	if($operation!='jscall') $strkeys[] = 'targettplname';
	$randkeys = array();
	$likekeys = array('name');
	$results = getwheres($intkeys, $strkeys, $randkeys, $likekeys);
	foreach((array)$likekeys as $k) {
		$_GET[$k] = htmlspecialchars(stripslashes($_GET[$k]));
	}
	$wherearr = $results['wherearr'];
	$mpurl .= '&'.implode('&', $results['urls']);
	$wherearr[] = $operation=='jscall' ? "blocktype='1'" : "blocktype='0'";
	$wheresql = empty($wherearr)?'1':implode(' AND ', $wherearr);
	$wheresql = str_replace(array('bid', 'blockclass', ' name', 'blocktype', 'targettplname'), array('b.bid', 'b.blockclass', ' b.name', 'b.blocktype', 'tb.targettplname'), $wheresql);
	$orders = getorders(array('bid', 'dateline'), 'bid');
	$ordersql = $orders['sql'];
	if($orders['urls']) $mpurl .= '&'.implode('&', $orders['urls']);
	$orderby = array($_GET['orderby']=>' selected');
	$ordersc = array($_GET['ordersc']=>' selected');

	$perpage = empty($_GET['perpage'])?0:intval($_GET['perpage']);
	if(!in_array($perpage, array(10,20,50,100))) $perpage = 20;
	$perpages = array($perpage=>' selected');
	$mpurl .= '&perpage='.$perpage;

	$searchlang = array();
	$keys = array('search', 'likesupport', 'resultsort', 'defaultsort', 'orderdesc', 'orderasc', 'perpage_10', 'perpage_20', 'perpage_50', 'perpage_100',
	'block_dateline', 'block_id', 'block_name', 'block_blockclass', 'block_add_jscall', 'block_choose_blockclass_to_add_jscall', 'block_diytemplate');
	foreach ($keys as $key) {
		$searchlang[$key] = cplang($key);
	}
	$diytemplatename_sel = '<select name="targettplname" id="targettplname">';
	$diytemplatename_sel .= '<option value="">'.cplang('diytemplate_name').'</option>';
	foreach((array)$_G['cache']['diytemplatename'] as $key=>$value) {
		$selected = ($key == $_GET['blockclass'] ? ' selected' : '');
		$diytemplatename_sel .= "<option value=\"$key\"$selected>$value</option>";
	}
	$diytemplatename_sel .= '</select>';
	$blockclass_sel = '<select name="blockclass" id="blockclass">';
	$blockclass_sel .= '<option value="">'.cplang('blockstyle_blockclass_sel').'</option>';
	foreach((array)$_G['cache']['blockclass'] as $key=>$value) {
		foreach((array)$value['subs'] as $subkey=>$subvalue) {
			$subvalue['name'] = lang('block', $subvalue['name']);
			$selected = ($subkey == $_GET['blockclass'] ? ' selected' : '');
			$blockclass_sel .= "<option value=\"$subkey\"$selected>$subvalue[name]</option>";
		}
	}
	$blockclass_sel .= '</select>';
	$addjscall = $operation == 'jscall' ? '<input type="button" class="btn" onclick="addjscall()" value="'.$searchlang['block_add_jscall'].'" />' : '';
	$firstrow = $operation == 'jscall' ? "<th>$searchlang[block_blockclass]</th><td colspan=\"3\">$blockclass_sel $addjscall</td>" : "<th>$searchlang[block_diytemplate]</th><td>$diytemplatename_sel</td><th>$searchlang[block_blockclass]</th><td colspan=\"2\">$blockclass_sel $addjscall</td>";
	$adminscript = ADMINSCRIPT;
	echo <<<SEARCH
			<script type="text/javascript" src="{$_G[siteurl]}static/js/portal.js"></script>
			<div id="ajaxwaitid"></div>
			<form method="get" autocomplete="off" action="$adminscript" id="tb_search">
				<div style="margin-top:8px;">
					<table cellspacing="3" cellpadding="3">
						<tr>
							$firstrow
						</tr>
						<tr>
							<th>$searchlang[block_id]</th><td><input type="text" class="txt" name="bid" value="$_GET[bid]"></td>
							<th>$searchlang[block_name]*</th><td><input type="text" class="txt" name="name" value="$_GET[name]">*$searchlang[likesupport]</td>
						</tr>
						<tr>
							<th>$searchlang[resultsort]</th>
							<td colspan="3">
								<select name="orderby">
								<option value="">$searchlang[defaultsort]</option>
								<option value="dateline"$orderby[dateline]>$searchlang[block_dateline]</option>
								</select>
								<select name="ordersc">
								<option value="desc"$ordersc[desc]>$searchlang[orderdesc]</option>
								<option value="asc"$ordersc[asc]>$searchlang[orderasc]</option>
								</select>
								<select name="perpage">
								<option value="10"$perpages[10]>$searchlang[perpage_10]</option>
								<option value="20"$perpages[20]>$searchlang[perpage_20]</option>
								<option value="50"$perpages[50]>$searchlang[perpage_50]</option>
								<option value="100"$perpages[100]>$searchlang[perpage_100]</option>
								</select>
								<input type="hidden" name="action" value="block">
								<input type="hidden" name="operation" value="$operation">
								<input type="submit" name="searchsubmit" value="$searchlang[search]" class="btn">
							</td>
						</tr>
					</table>
				</div>
			</form>
			<script type="text/javascript">
			function addjscall() {
				var blockclass = $('#blockclass').val();
				if(blockclass) {
					showWindow('blockclass', 'index.php?option=block&op=block&blocktype=1&from=cp&classname=' + blockclass);
				} else {
					alert('$searchlang[block_choose_blockclass_to_add_jscall]');
				}
			}
			</script>
SEARCH;

	$start = ($page-1)*$perpage;

	showformheader('block&operation='.$operation);
	showtableheader('block_list');

	include_once libfile('function/block');
	if($operation=='jscall') {
		showsubtitle(array('', 'block_name', 'block_script', 'block_style', 'block_dateline', 'operation'));
		$multipage = '';
		$count = DB::result(DB::query("SELECT COUNT(*) FROM #__common_block b WHERE $wheresql"), 0);
		if($count) {
			$query = DB::query("SELECT * FROM #__common_block b WHERE $wheresql $ordersql LIMIT $start,$perpage");
			while($value = DB::fetch($query)) {
				$theclass = block_getclass($value['blockclass'], true);
				showtablerow('', array('class="td25"'), array(
				"<input type=\"checkbox\" class=\"checkbox\" name=\"ids[]\" value=\"$value[bid]\">",
				!empty($value['name']) ? $value['name'] : cplang('block_name_null'),
				$theclass['script'][$value['script']],
				$value['styleid'] ? $theclass['style'][$value['styleid']]['name'] : lang('portalcp', 'blockstyle_diy'),
				!empty($value['dateline']) ? dgmdate($value['dateline']) : cplang('block_dateline_null'),
				"<a href=\"index.php?option=block&op=block&bid=$value[bid]&blocktype=1&from=cp\" target=\"_blank\" onclick=\"showWindow('showblock',this.href);return false;\">".cplang('block_setting')."</a> &nbsp;&nbsp".
				"<a href=\"index.php?option=block&op=data&bid=$value[bid]&blocktype=1&from=cp\" target=\"_blank\" onclick=\"showWindow('showblock',this.href);return false;\">".cplang('block_data')."</a> &nbsp;&nbsp".
				"<a href=\"javascript:;\" onclick=\"prompt('".cplang('block_copycode_message')."', '<!--{block/$value[bid]}-->')\">".cplang('block_copycode_inner')."</a> &nbsp;&nbsp".
				"<a href=\"javascript:;\" onclick=\"prompt('".cplang('block_copycode_jsmessage')."', '&lt;script type=&quot;text/javascript&quot; src=&quot;$_G[siteurl]api.php?mod=js&bid=$value[bid]&quot;&gt;&lt;/script&gt;')\">".cplang('block_copycode_outer')."</a>"
				));
			}
			$multipage = multi($count, $perpage, $page, $mpurl);
		}

		showsubmit('', '', '', '<input type="checkbox" name="chkall" id="chkall" class="checkbox" onclick="checkAll(\'prefix\', this.form, \'ids\')" /><label for="chkall">'.cplang('select_all').'</label>&nbsp;&nbsp;<input type="submit" class="btn" name="deletesubmit" value="'.cplang('block_delete').'" />', $multipage);
		showtablefooter();
		showformfooter();

	} else {

		showsubtitle(array('block_name', 'block_script', 'block_style', 'block_dateline', 'block_page', 'operation'));
		$multipage = '';
		$count = DB::result(DB::query("SELECT COUNT(*) FROM #__common_block b LEFT JOIN #__common_template_block tb ON tb.bid=b.bid WHERE $wheresql"), 0);
		if($count) {
			$query = DB::query("SELECT b.*, tb.targettplname FROM #__common_block b LEFT JOIN #__common_template_block tb ON b.bid=tb.bid WHERE $wheresql $ordersql LIMIT $start,$perpage");
			while($value = DB::fetch($query)) {
				$theclass = block_getclass($value['blockclass'], true);
				$diyurl = block_getdiyurl($value['targettplname']);
				$diypage = '';
				if ($diyurl['flag'] == 0) {
					$diypage = "<a href=\"$diyurl[url]\" target=\"_blank\">".$_G['cache']['diytemplatename'][$value['targettplname']]."</a>";
				} elseif ($diyurl['flag'] == 1) {
					$diypage = cplang('block_page_pub');
				} elseif ($diyurl['flag'] == 2) {
					$diypage = cplang('block_page_unused');
				}
				showtablerow('', '', array(
				$value['name'] ? $value['name'] : cplang('block_name_null'),
				$theclass['script'][$value['script']],
				$value['styleid'] ? $theclass['style'][$value['styleid']]['name'] : lang('portalcp', 'blockstyle_diy'),
				!empty($value['dateline']) ? dgmdate($value['dateline']) : cplang('block_dateline_null'),
				$diypage,
				"<a href=\"index.php?option=block&op=block&bid=$value[bid]&from=cp\" target=\"_blank\" onclick=\"showWindow('showblock',this.href);return false;\">".cplang('block_setting')."</a> &nbsp;&nbsp"
				."<a href=\"index.php?option=block&op=data&bid=$value[bid]&from=cp\" target=\"_blank\" onclick=\"showWindow('showblock',this.href);return false;\">".cplang('block_data')."</a> &nbsp;&nbsp"
				.$diyop
				));
			}
			$multipage = multi($count, $perpage, $page, $mpurl);
		}

		showsubmit('', '', '', '<input type="submit" class="btn" name="clearsubmit" value="'.cplang('block_clear_unused').'" />', $multipage);
		showtablefooter();
		showformfooter();
	}
}
